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SPECIFICATION 



MAXIMIZED DATA SPACE IN SHARED MEMORY BETWEEN 

PROCESSORS 

BACKGROUND OF THE INVENTION 
5 1. Field of the Invention 

The present invention relates to use of shared memory 
between multiple processors for communicating command messages and 
payload data therebetween. More particularly, it relates to an efficient 
architecture and system design for efficiently assigning shared memory 
10 locations as a full duplex mailbox. 

2. Background of Related Art 

Digital memory is found in nearly every digital electronic 
device, particularly when such device includes a processor (e.g., a 

15 microprocessor, microcontroller, or digital signal processor). Many types 
of digital memory exist, perhaps the most common form being random 
access memory (RAM). 

With advancements in technology came the need to include 
more than one processor in a device. While each processor (or other) 

20 device has its own assigned tasks, information is typically made available 
to either processor through the use of a commonly accessible memory, 
e.g., RAM. This commonly accessible memory may be dual port memory 
or simply a shared memory area having an individual address and data 
bus (i.e., port) for each accessing processor. 

25 Two processors (e.g., a microprocessor unit (MPU) and a 

digital signal processor (DSP)) may utilize shared memory to 
cooperatively pass command information to one another, and/or to pass 
more lengthy payload data (e.g., digitized voice messages) back and 
forth. Such a use of the shared memory is often referred to as a "shared 

30 mailbox" or simply a "mailbox". 
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In a shared memory mailbox, a first processor or other 
device writes to a particular address/data location(s) of the shared 
memory, and the second processor or other device reads from that 
particular address/data location(s). 
5 Fig. 4 shows a conventional shared memory 504, e.g., a 

dual port memory, serving as a message mailbox between two 
processors. In Fig. 4, the shared memory 504 has a first port 579 
including an address and data bus connected to a first processor 500, and 
a second port 589 including another address and data bus connected to a 

10 second processor 502. 

Depending upon the particular application, an incoming 
mailbox and an outgoing mailbox for a particular processor may be of 
different sizes. For instance, in Fig. 4, the shared memory 504 is 
configured for use by either processor 500, 502 by providing a moveable 

15 partition in the memory space of the common memory 504. For instance, 
if the common memory 504 is a 2K word memory, the first 1K (i.e., 0 to 
1K) may be assigned for use by the first processor 500 while the second 
1 K (i.e., 1 K to 2K) may be assigned for use by the second processor 502. 
The partitioned portions of the shared memory are mapped into the 

20 memory map of the respective processors, and form the boundaries of the 
two mailboxes providing bi-directional messaging between the two 
processors 500, 502. 

The challenges of using a dual access RAM or other shared 
memory 504 to pass messages between processors 500, 502 are well 

25 known. For instance, use of the shared, common memory 504 as a 
message mailbox between the two processors 500, 502, requires that 
both processors 500, 502 have access to common memory locations. To 
pass messages from the first processor 500 to the second processor 502, 
the first processor 500 must be given write access to that particular 
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memory location, and the second processor 502 must be given read 
access to read that same memory location to receive the message. 

As shown in Fig. 5, from an external perspective, it appears 
as if either processor 500, 502 can access any memory location 530-545 
5 in the shared memory 504 at any time. For instance, in the example 
shown in Fig. 5, the first processor 500 is addressing memory location 
535, and the memory location 535 is allowing an appropriate write 
operation (or other operation) on the first data bus DATA 1 corresponding 
to the first processor 500. At the same time, the second processor 502 is 

10 accessing memory location 542 using its corresponding address and data 
buses ADDR2, DATA 2. 

The example of Fig. 5 shows proper simultaneous access to 
separate and distinct memory locations 535 and 542 by the respective 
processors 500, 502 using conventional dual port memory 504. However, 

15 as shown in the example of Fig. 6, a collision would occur in the event that 
both processors 500, 502 try to simultaneously write to the same memory 
location 542. In this case, an unpredictable state would occur with 
respect to data output on the respective data buses DATA 1 , DATA 2. 

Conflicts may occur between the two processors 500, 502, 

20 e.g., if an access from either processor 500, 502 to any particular memory 
location is overlapped with an access by the other. Thus, designers 
attempt to avoid race conditions and corruption of data caused by the 
potential for simultaneous or substantially simultaneous access of a 
particular memory location by both processors 500, 502. 

25 To avoid overwriting or otherwise colliding with each other's 

data space, the shared memory 504 can be physically or logically 
separated into two mailbox segments. This technique works, but is not 
flexible enough to efficiently accommodate large payload data transfers 
from either processor to the other without requiring reconfiguring of the 
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partition in the shared memory 504 between the mailbox message 
directions. 

Another conventional method provides for dynamic 
allocation of the shared memory space 504 to only one processor at a 
5 time to avoid collisions (i.e., multiplexed access), but this technique does 
not maximize use of the shared data space, slows down full duplex (i.e., 
bi-directional) message transfer, and causes some longer payload 
messages to be passed in non-contiguous portions of the shared memory 
504 which also slows down data transfer of the payload data from the 
10 shared memory 504 by the receiving processor. 

Another technique to prevent collisions in accesses to 
common memory is to synchronize the accesses of the two processors 
500, 502 to be not coincidental in time with one another, e.g., allowing 
alternating access on a word or other basis by the two processors 500, 
15 502 to the shared memory 504. However, this technique slows down the 
data or payload transfer rate in both directions. 

There is a need for an efficient technique and apparatus for 
using shared memory to form a bi-directional mailbox for command 
messages and/or payload data between two processors. 

20 

SUMMARY OF THE INVENTION 

In accordance with the principles of the present invention, a 
shared memory processor-to-processor mailbox between at least two 
processors comprises a shared memory accessible by a first processor 

25 and a second processor. The shared memory includes a first mailbox 
portion to pass data from the first processor to the second processor, and 
a second mailbox portion to pass data from the second processor to the 
first processor. The first mailbox portion starts at a low physical address 
end of the shared memory, and fills upward toward a high physical 

30 address of the shared memory. The second mailbox portion starts at the 
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high physical address end of the shared memory, and fills downward 
toward the low physical address of the shared memory. The first 
processor has write access to the first mailbox portion and not to the 
second mailbox portion. 
5 A method of utilizing a shared memory as a mailbox 

between two processors in accordance with another aspect of the present 
invention comprises allocating first direction messages passed from a first 
processor to a second processor to a first physical address end of the 
shared memory. Second direction messages passed from the second 

10 processor to the first processor are allocated to a second physical 
address end of the shared memory opposite the first physical address 
end. The first direction messages are allowed to utilize a dynamically 
allocated central portion of the shared memory growing toward the second 
physical address end. The second direction messages are allowed to 

15 utilize the dynamically allocated central portion of the shared memory 
growing toward the first physical address end. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Features and advantages of the present invention will 
20 become apparent to those skilled in the art from the following description 
with reference to the drawings, in which: 

Fig. 1A shows a shared memory having an exemplary 
assignment of memory locations forming a bi-directional mailbox between 
two processors, in accordance with the principles of a first embodiment of 
25 the present invention. 

Fig. 1B is a more detailed depiction of the allocation and 
assignment of the shared memory shown in Fig. 1A. 

Fig. 2 shows an assignment of memory locations in a shared 
memory processor-to-processor mailbox in opposing directions as 
30 between two processors, including the example of dynamic allocation of 
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buffer space between the two ends of the shared memory to the first 
processor, in accordance with the principles of a first embodiment of the 
present invention. 

Fig. 3 shows an assignment of memory locations in a shared 
5 memory processor-to-processor mailbox in opposing directions as 
between two processors, including the example of dynamic allocation of 
buffer space between the two ends of the shared memory to the second 
processor, in accordance with the principles of a first embodiment of the 
present invention. 

10 Fig. 4 shows a conventional dual port, common memory 

having first and second ports communicating with respective processors. 

Fig. 5 depicts a conventional access to separate memory 

locations by two processors communicating with respective ports of a dual 

port, common memory. 
15 Fig. 6 shows a conventional access to the same memory 

location in a dual port, common memory resulting in a collision in 

accesses from two respective processors. 

DETAILED DESCRIPTION OF ILLUSTRATIVE EMBODIMENTS 

20 This invention provides a technique and apparatus for 

efficiently and flexibly utilizing shared memory as a full duplex mailbox for 
both data and payload information. The invention allows payload 
messages of varying lengths to be passed in contiguous memory space, 
allowing an interrupt service routine (ISR) or other process to easily and 

25 quickly read or cache the passed payload data. 

Fig. 1A shows a shared memory having an exemplary 
assignment of memory locations forming a bi-directional mailbox between 
two processors, in accordance with the principles of a first embodiment of 
the present invention. 
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In Fig. 1, a processor-to-processor mailbox 100 is formed 
using a shared memory (e.g., a dual port RAM). The shared memory is 
separated into three main portions: a processor 1 to processor 2 fixed 
portion 40, a processor 2 to processor 1 fixed portion 44, and an 
5 unallocated dynamic portion 42. 

The processor 1 to processor 2 fixed portion 40 may be 
used for passing commands or other messages and/or payload data from 
a first processor to a second processor. Ideally, the processor 1 to 
processor 2 fixed portion 40 remains available for short, normal command 
10 messages in the direction from the first processor to the second 
processor. 

Importantly, the other direction of the mailbox is located 
starting at the highest address of the shared memory, and working toward 
the lowest address of the shared memory. In particular, the processor 2 

15 to processor 1 fixed portion 44 may be used for passing commands or 
other messages and/or payload data from the second processor to the 
first processor. Ideally, the processor 2 to processor 1 fixed portion 44 
remains available for short, normal command messages in the direction 
from the first processor to the second processor. 

20 Preferably, payload messages and other generally longer 

messages are dynamically allocated in the unallocated dynamic portion 
42 for use by both processors. For messages passed in mailbox 1 , i.e., 
from processor 1 to processor 2, the memory in the unallocated dynamic 
portion 42 is allocated in a lowest to highest address direction. 

25 Conversely, for messages passed in mailbox 2, i.e., from processor 2 to 
processor 1, the memory in the unallocated dynamic portion 42 is 
allocated in a highest to lowest address direction. 

Ideally, the total size of the shared memory is sized so as to 
statistically accommodate the maximum total length requirements of both 

30 mailboxes 1 , 2. Use of the unallocated dynamic portion 42 may or may 
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not be regulated as between the two processors. For instance, the 
particular application may accommodate the statistical improbability that 
the unallocated dynamic portion 42 will be overrun by messages in a 
particular direction (e.g., in certain voice applications). However, 
allocation (and therefore write access) to a used portion of the unallocated 
dynamic may be prevented until the buffered message is read by the 
appropriate processor. 

Fig. 1B is a more detailed depiction of the allocation and 
assignment of the shared memory shown in Fig. 1A. 

In particular, Fig. 1B depicts the shared memory having a 
total length of 64 words. Of course, the principles of the present invention 
relate equally to shared memory of any size, e.g., much smaller or much 
larger than 64 words. 

In Fig. 1B, the processor-to-processor mailbox 100 
comprises an MPU to DSP command portion 40, a DSP to MPU 
command portion 44, and an unused dynamically allocated portion 42. In 
the given example, the MPU to DSP portion 40 is allocated to be a 
minimum of eight (8) words in length starting at address 0 and filling up, 
and the DSP to MPU portion 44 is allocated to be a minimum of eight (8) 
words in length starting at address 63 and filling downwards. The unused 
dynamically allocated portion 42 utilizes the central portion of the shared 
memory, e.g., the central forty-eight (48) words. 

In accordance with the principles of the present invention, a 
first processor (e.g., the MPU) accessing the shared memory of the bi- 
directional mailbox 100 is memory mapped to have write access to the 
shared memory from the beginning (e.g., from address zero (0)), and fills 
upwards toward the higher physical addresses of the shared memory, 
while the second processor (e.g., DSP) starts passing messages in the bi- 
directional mailbox 100 at the highest address of the shared memory 
(e.g., from address 2K-1 shown in Fig. 1B, and fills downwards toward the 
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lower physical addresses of the shared memory. Thus, the second 
processor (e.g., DSP) write accesses the shared memory in reverse order 
beginning at the top of the shared memory (i.e., the highest address of the 
shared memory). 

5 In the preferred embodiment, while although the first 

processor MPU has write access in an allocated direction starting at the 
bottom (e.g., 0 address) of the shared memory and filling upwards, and 
the second processor DSP has write access in an allocated direction 
starting at the top (e.g., 2K-1 address) of the shared memory and filling 
10 downwards, both processors MPU and DSP have read access to all or 
substantially all of the shared memory forming the processor-to-processor 
mailbox. 

Preferably, each side of the shared memory (i.e., the 
processor 1 to processor 2 command space 40 and the processor 2 to 
15 processor 1 command space 44 has a defined minimum message size 
and memory location(s) reserved to allow all normal messages (e.g., 
command messages) to be passed no matter how much space in the 
shared memory the other side is allocated. In the embodiment shown in 
Fig. 1B the minimum message size is 1 word and the minimum number of 
20 message locations reserved are a total of eight (8). 

If a larger amount of space in the processor-to-processor 
mailbox 100 is required by either processor to pass, e.g., a large payload 
data message, an appropriate command message can be first transmitted 
to the other processor to request (or demand) access to a sufficient 
25 amount of the shared memory to accomplish the desired task, and the 
other processor would refrain from utilizing that dynamically allocated 
portion 42 of the processor-to-processor mailbox 100. 

When one processor (e.g., the MPU) requires extra space in 
the shared memory for transmitting a large amount of data, it can 
30 maximize the allocation of shared memory, e.g., as shown in Fig. 2. 
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Fig. 2 shows an assignment of memory locations in a shared 
memory processor-to-processor mailbox in opposing directions as 
between two processors, including the example of dynamic allocation of 
buffer space between the two ends of the shared memory to the first 

5 processor, in accordance with the principles of a first embodiment of the 
present invention. 

In particular, in Fig. 2, not only is all of the dynamically 
allocated space 42 allocated to the MPU for passing a data payload to the 
DSP, but a portion of the fixed command space 40 (e.g., the third through 

10 eighth command reservations 113-118) are also used for passage of the 
lengthy information from the first processor (e.g., MPU) to the second 
processor (e.g., DSP). 

Conversely to Fig. 2, when the other processor (e.g., a DSP) 
serviced by the other side of the processor-to-processor mailbox 100 

15 requires extra space to transmit a larger amount of data (either larger 
number of messages and/or a larger amount of payload data), it can 
maximize the shared memory, e.g., as shown in Fig. 3. 

Fig. 3 shows an assignment of memory locations in a shared 
memory processor-to-processor mailbox in opposing directions as 

20 between two processors, including the example of dynamic allocation of 
buffer space between the two ends of the shared memory to the second 
processor, in accordance with the principles of a first embodiment of the 
present invention. 

In particular, in Fig. 3, not only is all of the dynamically 

25 allocated space 42 allocated to the DSP for passing a data payload to the 
MPU, but a portion of the fixed command space 40 (e.g., the third through 
eighth command reservations 183-188) are also used for passage of the 
lengthy information from the first processor (e.g., DSP) to the second 
processor (e.g., MPU). 
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As shown in Figs. 2 and 3, as one side of the processor-to- 
processor mailbox 100 requires additional data space, it not only uses the 
previously unused dynamic space but it can be allocated some of its own 
command header space 40, 44. In this way, as memory is allocated to 
5 one side of the mailbox or the other, it remains contiguous with the rest of 
the mailbox buffer. 

An interrupt service routine (ISR) may be used in either or 
both processors to read the messages from the respective side of the 
shared memory forming its incoming mailbox buffer. In accordance with 

10 the principles of the present invention, such an ISR would be capable of 
efficiently processing the transfer of information from the incoming 
mailbox buffer to internal RAM or other location, particularly since the 
transferred data would be in a contiguous portion of the shared memory. 
This allows a data transfer using a tight loop (possibly cached) to reduce 

15 time in the interrupt service routine (ISR). 

Similarly, the ISR in a second processor (e.g., the DSP) can 
copy the internal ram buffer to the upside down buffer portion 44 in 
shared memory in "reverse" order so the rest of the code would simply fill 
the RAM buffer "right side up". The first processor (e.g., the MPU) can 

20 reverse the order of the shared memory as it copies it into internal RAM, 
and the remainder of the code of the MPU would process the RAM data 
as if it were "right side up". 

Using this method of data transfer, each processor having 
access to the DPRAM would have to request (or demand) access to the 

25 shared memory, e.g., forming a dynamic mailbox space. This can be 
performed, e.g., using a command/response sequence limited to certain 
locations in the DPRAM, e.g., called mailbox command space. 

One possible implementation is for one processor, say the 
DSP, to have access to the dynamic mailbox space. The only way the 

30 MPU would be allowed to write to it is if the MPU requested write access 
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to it (e.g., via a command passed to the DSP, via an input/output (I/O) 
pin, via an interrupt to DSP, etc.) and its request for write access was 
granted by the DSP. 

Once the MPU has completed its write access to memory 
5 space ordinarily utilized by the DSP, it can send a command to the DSP 
indicating that it is relinquishing control of the shared mailbox space. 

Sharing of memory locations in opposing order as described 
provides many advantages. For instance, in a telephone answering 
device application, it can allow use of a maximum amount of memory 
10 space for both voice data stored from a DSP and call related information 
such as Caller ID stored from a MPU. In this way, data is less likely to be 
inefficiently split up over multiple memory blocks. 

Moreover, in the telephone answering device (TAD) 
application, the opposing storage of data in a shared memory space 
15 allows a TAD to maximize playback speech frames in one direction, and 
to maximize record speech frames in the other direction, providing an 
efficiently managed record/playback memory space. 

Furthermore, the speed of interrupt service routines (ISRs) 
can be reduced, saving energy and processor speed requirements. 
20 Overall, the principles of the present invention has the potential to almost 
double the possible throughput from one processor to another with very 
little overhead. 

While the invention has been described with reference to the 
exemplary embodiments thereof, those skilled in the art will be able to 
25 make various modifications to the described embodiments of the invention 
without departing from the true spirit and scope of the invention. 
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CLAIMS 



What is claimed is: 

1. A shared memory processor-to-processor mailbox 
5 between at least two processors, comprising: 

a shared memory accessible by a first processor and a 
second processor, said shared memory including a first mailbox portion to 
pass data from said first processor to said second processor, and a 
second mailbox portion to pass data from said second processor to said 
10 first processor; 

said first mailbox portion starting at a low physical address 
end of said shared memory, and filling upward toward a high physical 
address of said shared memory; 

said second mailbox portion starting at said high physiceT^ 
15 address end of said shared memory, and filling downward toward said low 
physical address of said shared memory; and 

said first processor having write access to said first mailbox 
portion and not to said second mailbox portion. 

20 2. The shared memory processor-to-processor mailbox 

between at least two processors according to clajmj , wherein: 

said second processor has write access to said second 
mailbox portion and not said first mailbox portion. 

25 3. The shared memory processor-to-processor mailbox 

between at least two processors according to claimjl/wherein: 

said first processor has read access to said first mailbox 
portion and to said second mailbox portion. 
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4. The shared memory processor-to-processor mailbox 
between at least two processors according to claim 3, wherein: 

said second processor has read access to said first mailbox 
portion and to said second mailbox portion. < t 

5 

5. The shared memory processor-to-processor mailbox 
between at least two processors according to claim 1, wherein: 

said shared memory is a dual port randorn access memory. 

10 6. The shared memory processor-to-processor mailbox 

between at least two processors according to claim 1 , wherein: 

said first processor has read access from both said first 
mailbox portion and said second mailbox portierTwhile having write 
access to said first mailbox portion and not to said second mailbox 

15 portion. 



7. The shared memory processor-to-processor mailbox 
between at least two processors according to claim 6, wherein: 

said second processor has read access^frefrrbbth said first 
20 mailbox portion and said second mailbox portion while having write 
access to said second mailbox portion and not to said first mailbox 
portion. 
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8. A method of utilizing a shared memory as a mailbox 
between two processors, comprising: 

allocating first direction messages passed from a first 
processor to a second processor to a first physical address end of said 
5 shared memory; 

allocating second direction messages passed from said 
second processor to said first processor to a second physical address end — 
of said shared memory opposite said first physical address end; 

allowing said first direction messages to utilize a dynamically 
10 allocated central portion of said shared memory growing toward said 
second physical address end; and 

allowing said second direction messages to utilize said 
dynamically allocated central portion of said shared memory growing 
toward said first physical address end. 
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9. The method of utilizing a shared memory as a mailbox 
between two processors according to claim 8, further comprising: 

assigning a minimum len§th~to said first physical address 

end. 

10. The method of utilizing a shared memory as a mailbox 
between two processors according to claim 9, further comprising: 

assigning a minimum lengtMo-said second physical address 

end. 



1 1 . The method of utilizing a shared memory as a mailbox 
between two processors according to claim 8, further comprising: 

reallocating a portion of a minimum length of said first 
physical address end of said shared memory to enlarge a size of said 
30 dynamically allocated central portion utilized by said first processor. 
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12. The method of utilizing a shared memory as a mailbox 
between two processors according to claim 1 1 , further comprising: 

reallocating a portion of a minimum length of said second 
physical address end of said shared memory to enlarge a size of said 
5 dynamically allocated central portion utilized by said second processor. 

13. Apparatus for utilizing a shared memory as a mailbox 
between two processors, comprising: 

means for allocating first direction messages passed from a 
10 first processor to a second processor to a first physical address end of 
said shared memory; 

means for allocating second direction messages passed 
from said second processor to said first processor to a second physical 
address end of said shared memory opposite said first physical address 
15 end; 

means for allowing said first direction messages to utilize a 
dynamically allocated central portion of said shared memory growing 
toward said second physical address end; and 

means for allowing said second direction messages to utilize 
20 said dynamically allocated central portion of said shared memory growing 
toward said first physical address end. 

14. The apparatus for utilizing a shared memory as a 
mailbox between two processors according to claim 13, further 

25 comprising: 

means for assigning a minimum length to said first physical 

address end. 
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15. The apparatus for utilizing a shared memory as a 
mailbox between two processors according to claim 14, further 
comprising: 

/. 

means for assigning a minimum length to said second 
5 physical address end. 

16. The apparatus for utilizing a shared memory as a 
mailbox between two processors according to claim 14, further 
comprising: 

10 reallocating a portion of a minimum length ^oT said first 

physical address end of said shared memory to enlarge a size of said 
dynamically allocated central portion utilized by said first processor. 

17. The apparatus for utilizing a shared memory as a 
15 mailbox between two processors according to claim 16, further 

comprising: 

means for reallocating a portion of a minimum length of said 
second physical address end of said shared memory to enlarge a size of 
said dynamically allocated central portion utilized by said second 
20 processor. 
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ABSTRACT 

A technique and apparatus for efficiently and flexibly utilizing 
shared memory as a full duplex mailbox for both data and payload 
information. The invention allows payload messages of varying lengths to 
5 be passed in contiguous memory space, allowing an interrupt service 
routine (ISR) or other process to easily and quickly read or cache the 
passed payload data. In a disclosed embodiment, a processor-to- 
processor mailbox is formed using a shared memory (e.g., a dual port 
RAM). The shared memory is separated into three main portions: a 

10 processor 1 to processor 2 fixed portion, a processor 2 to processor 1 
fixed portion, and an unallocated dynamic portion. Importantly, the other 
direction of the mailbox is located starting at the highest address of the 
shared memory, and works toward the lowest address of the shared 
memory. Preferably, write access for payload messages and other 

15 generally longer messages are dynamically allocated in the unallocated 
dynamic portion for use in either mailbox. For messages passed in 
mailbox 1, i.e., from processor 1 to processor 2, the memory in the 
unallocated dynamic portion is allocated in a lowest to highest address 
direction. Conversely, for messages passed in mailbox 2, i.e., from 

20 processor 2 to processor 1, the memory in the unallocated dynamic 
portion is allocated in a highest to lowest address direction. 
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IN THE UNITED STATES 
PATENT AND TRADEMARK OFFICE 

Declaration and Power of Attorney 

As the below named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below next to 
my name. 

I believe I am the original, first and sole inventor of the subject matter which ts 
claimed and for which a patent Is sought on the invention entitled MAXIMIZED 
DATA SPACE IN SHARED MEMORY BETWEEN PROCESSORS the specification 
of which is attached hereto. 

I hereby state that I have reviewed and understand the contents of the above 
identified specification, including the claims, as amended by an amendment, if any, 
specifically referred to in this oath or declaration. 

I acknowledge the duty to disclose all information known to me which is 
material to patentability as defined in Title 37, Code of Federal Regulations, 1 .56. 

I hereby claim foreign priority benefits under Title 35, United States Code, 
119 of any foreign appllcation(s) for patent or inventor's certificate listed below and 
have also identified below any foreign application for patent or inventor's certificate 
having a filing date before that of the application on which priority is claimed: 

None 

I hereby claim the benefit under Title 35, United States Code, 120 of any 
United States application(s) listed below and, insofar as the subject matter of each 
of the claims of this application is not disclosed in the prior United States application 
in the manner provided by the first paragraph of Title 35, United States Code, 1 12, 1 
acknowledge the duty to disclose all information known to me to be material to 
patentability as defined In Title 37, Code of Federal Regulations, 1.56 which became 
available between the filing date of the prior application and the national or PCT 
international filing date of this application: 

None 

I hereby declare that all statements made herein of my own knowledge are 
true and that all statements made on Information and belief are believed to be true; 
and further that these statements were made with the knowledge that willful false 
statements and the like so made are punishable by fine or imprisonment, or both, 
under Section 1001 of Title 18 of the United States Code and that such willful false 
statements may jeopardize the validity of the application or any patent Issued 
thereon. 
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I hereby appoint the following attorney(s) with full power of substitution and 
revocation, to prosecute said application, to make alterations and amendments 
therein, to receive the patent, and to transact all business in the Patent and 
Trademark Office connected therewith: 



Lester H. Birnbaum 
Richard J. Botos 
Jeffery J. Brosemer 
Kenneth M. Brown 
Craig J. Cox 
Donald P. Dinella 
Guy Eriksen 
Martin I. Finston 
James H. Fox 
William S. Francos 
Barry H. Freedman 
Julio A. Garceran 
Mony R. Ghose 
Jimmy Goo 
Anthony Grillo 
Stephen M. Gurey 
John M. Harman 
Michael B. Johannesen 
Mark A. Kurisko 
Irena Lager 

Christopher N. Malvone 
Scott W. McLellan 
Martin G. Meder 
John C. Moran 
Michael A. Morra 
Gregory J. Murgia 
Claude R. Narcisse 
Joseph J. Opalach 
Neil R. Ormos 
Eugen E. Pacher 

Jack R. Penrod 
Daniel J. Piotrowski 

Gregory C. Ranieri 

Scott J. Rittman 
Eugene J. Rosenthal 
Bruce S. Schneider 
Ronald D. Slusky 
David L. Smith 
Patricia A. Verlangieri 
John P. Veschl 
David Volejnicek 
Charles L. Warren 

Jeffrey M. Weinick 



(Reg. No. 25830) 
(Reg. No, 32016) 
(Reg. No. 36096) 
(Reg. No. 37590) 
(Reg. No. 39643) 
(Reg. No. 39961) 
(Reg. No. 41736) 
(Reg. No. 31613) 
(Reg. No. 29379) 
(Reg. No. 38456) 
(Reg. No. 26166) 
(Reg. No. 37138) 
(Reg. No. 38159) 
(Reg. No. 36528) 
(Reg. No. 36535) 
(Reg. No. 27336) 
(Reg. No. 38173) 
(Reg. No. 35557) 
(Reg. No. 38944) 
(Reg. No. 39260) 
(Reg. No. 34866) 
(Reg. No. 30776) 
(Reg. No. 34674) 
(Reg. No. 30782) 
(Reg. No. 28975) 
(Reg. No. 41209) 
(Reg. No. 38979) 
(Reg. No. 36229) 
(Reg. No. 35309) 
(Reg. No. 29964) 
(Reg. No. 31864) 
(Reg. No. 42079) 
(Reg. No. 29695) 

(Reg. No. 39010) 
(Reg. No. 36658) 
(Reg. No. 27949) 
(Reg. No. 26585) 
(Reg. No. 30592) 
(Reg. No. 42201) 
(Reg. No. 39058) 
(Reg. No. 29355) 
(Reg. No. 27407) 

(Reg. No. 36304) 
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Ell Weiss 



(Reg. No. 17765) 



I hereby appoint the attorney(s) on ATTACHMENT A as associate attorney(s) 
In the aforementioned application, with full power solely to prosecute said 
application, to make alterations and amendments therein, to receive the patent, and 
to transact all business in the Patent and Trademark Office connected with the 
prosecution of said application. No other powers are granted to such associate 
attorney(s) and such associate attorney(s) are specifically denied any power of 
substitution or revocation. 



Full name oMst joint inventor: James A, JOH ANSON 

Residence: Lehigh County, Macungle, Pennsylvania 

Citizenship: USA 

Post Office Address: 6336 Laroh Circle, Macungle, Pennsylvania 18062 



Full name of 2nd joint inventor: Philip D. MOONEY 



Residence: Montgomej^County, North Wales, Pennsylvania 

Citizenship: USA 

Post Office Address: 508 De Kalb Pike, North Wales, Pennsylvania 19454 



Inventor's 
signature. 




Date I /A/ft 
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ATTACHMENT A 



Attorney Name(s): William H. Bollman Reg. No.: 36.457 



Telephone calls should be made to Farkas and Manelli PLLC at: 
Phone No,: 202-251 -1000 
Fax No.: 202-887-0336 



All written communications are to be addressed to: 

Farkas & Manelli pile 
2000 M Street, N.W. 
7 th Floor 
Washington, D.C. 20036-3307 
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